<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  
  <title>Java中的异常处理 | Hexo</title>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <meta name="description" content="异常在Java中是一个非常重要的概念，如果不用异常写程序，我们能写的代码寥寥无几，今天我们就看看java异常的一些注意事项。">
<meta property="og:type" content="article">
<meta property="og:title" content="Java中的异常处理">
<meta property="og:url" content="http://yoursite.com/2016/08/09/Java中的异常处理/index.html">
<meta property="og:site_name" content="Hexo">
<meta property="og:description" content="异常在Java中是一个非常重要的概念，如果不用异常写程序，我们能写的代码寥寥无几，今天我们就看看java异常的一些注意事项。">
<meta property="og:updated_time" content="2016-08-10T12:58:23.011Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="Java中的异常处理">
<meta name="twitter:description" content="异常在Java中是一个非常重要的概念，如果不用异常写程序，我们能写的代码寥寥无几，今天我们就看看java异常的一些注意事项。">
  
    <link rel="alternative" href="/atom.xml" title="Hexo" type="application/atom+xml">
  
  
    <link rel="icon" href="/img/favicon.png">
  
  
  <link rel="stylesheet" href="//cdn.bootcss.com/animate.css/3.5.0/animate.min.css">
  
  <link rel="stylesheet" href="/css/style.css">
  <link rel="stylesheet" href="/font-awesome/css/font-awesome.min.css">
  <link rel="apple-touch-icon" href="/apple-touch-icon.png">
  
  
      <link rel="stylesheet" href="/fancybox/jquery.fancybox.css">
  
  <!-- 加载特效 -->
    <script src="/js/pace.js"></script>
    <link href="/css/pace/pace-theme-flash.css" rel="stylesheet" />
  <script>
      var yiliaConfig = {
          fancybox: true,
          animate: true,
          isHome: false,
          isPost: true,
          isArchive: false,
          isTag: false,
          isCategory: false,
          open_in_new: false
      }
  </script>
</head>
<body>
  <div id="container">
    <div class="left-col">
    <div class="overlay"></div>
<div class="intrude-less">
    <header id="header" class="inner">
        <a href="/" class="profilepic">
            
            <img lazy-src="/img/head.jpg" class="js-avatar">
            
        </a>

        <hgroup>
          <h1 class="header-author"><a href="/">Abely Liu</a></h1>
        </hgroup>

        
        
        
            <div id="switch-btn" class="switch-btn">
                <div class="icon">
                    <div class="icon-ctn">
                        <div class="icon-wrap icon-house" data-idx="0">
                            <div class="birdhouse"></div>
                            <div class="birdhouse_holes"></div>
                        </div>
                        <div class="icon-wrap icon-ribbon hide" data-idx="1">
                            <div class="ribbon"></div>
                        </div>
                        
                        <div class="icon-wrap icon-link hide" data-idx="2">
                            <div class="loopback_l"></div>
                            <div class="loopback_r"></div>
                        </div>
                        
                        
                        <div class="icon-wrap icon-me hide" data-idx="3">
                            <div class="user"></div>
                            <div class="shoulder"></div>
                        </div>
                        
                    </div>
                    
                </div>
                <div class="tips-box hide">
                    <div class="tips-arrow"></div>
                    <ul class="tips-inner">
                        <li>菜单</li>
                        <li>标签</li>
                        
                        <li>友情链接</li>
                        
                        
                        <li>关于我</li>
                        
                    </ul>
                </div>
            </div>
        

        <div id="switch-area" class="switch-area">
            <div class="switch-wrap">
                <section class="switch-part switch-part1">
                    <nav class="header-menu">
                        <ul>
                        
                            <li><a href="/Home">博客首页</a></li>
                        
                            <li><a href="/works">作品展示</a></li>
                        
                            <li><a href="/about">留言打卡</a></li>
                        
                            <li><a href="/FrontEndGuide">前端导航</a></li>
                        
                        </ul>
                    </nav>
                    <nav class="header-nav">
                        <ul class="social">
                            
                                <a class="fl mail" target="_blank" href="http://mail.qq.com/cgi-bin/qm_share?t=qm_mailme&email=PAkNDgsKBQ4MCnxNTRJfU1E" title="mail">mail</a>
                            
                                <a class="fl github" target="_blank" href="https://github.com/luuman" title="github">github</a>
                            
                                <a class="fl zhihu" target="_blank" href="https://www.zhihu.com/people/luuman" title="zhihu">zhihu</a>
                            
                                <a class="fl weibo" target="_blank" href="http://weibo.com/lishangmou" title="weibo">weibo</a>
                            
                                <a class="fl google" target="_blank" href="http://i.youku.com/shangmou" title="google">google</a>
                            
                                <a class="fl twitter" target="_blank" href="http: //twitter.com/luuman" title="twitter">twitter</a>
                            
                                <a class="fl facebook" target="_blank" href="#" title="facebook">facebook</a>
                            
                                <a class="fl rss" target="_blank" href="/atom.xml" title="rss">rss</a>
                            
                        </ul>
                    </nav>
                </section>
                
                
                <section class="switch-part switch-part2">
                    <div class="widget tagcloud" id="js-tagcloud">
                        <a href="/tags/java/" style="font-size: 20px;">java</a> <a href="/tags/linux/" style="font-size: 10px;">linux</a> <a href="/tags/shell/" style="font-size: 10px;">shell</a> <a href="/tags/程序设计/" style="font-size: 10px;">程序设计</a> <a href="/tags/设计模式，java/" style="font-size: 10px;">设计模式，java</a>
                    </div>
                </section>
                
                
                
                <section class="switch-part switch-part3">
                    <div id="js-friends">
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://MOxFIVE.github.io/">MOxFIVE</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://www.vsay.cn/">DoubleV</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://www.ccwebsite.com/">兮兮</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://blog.dandyweng.com/">翁天信</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://www.plqblog.com/views/index.php">潘利强</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://www.hankin.cn/">hankin</a>
                    
                      <a target="_blank" class="main-nav-link switch-friends-link" href="http://blog.waydrow.com/">waydrow</a>
                    
                    </div>
                </section>
                

                
                
                <section class="switch-part switch-part4">
                
                    <div id="js-aboutme">纯海迷、爱运动、爱交友、爱旅行、喜欢接触新鲜事物、迎接新的挑战，更爱游离于错综复杂的编码与逻辑中</div>
                </section>
                
            </div>
        </div>
    </header>                
</div>
    </div>
    <div class="mid-col">
      <nav id="mobile-nav">
      <div class="overlay">
          <div class="slider-trigger"></div>
          <h1 class="header-author js-mobile-header hide"><a href="/" title="回到主页">Abely Liu</a></h1>
      </div>
    <div class="intrude-less">
        <header id="header" class="inner">
            <a href="/" class="profilepic">
                
                    <img lazy-src="/img/head.jpg" class="js-avatar">
                
            </a>
            <hgroup>
              <h1 class="header-author"><a href="/" title="回到主页">Abely Liu</a></h1>
            </hgroup>
            
            <nav class="header-menu">
                <ul>
                
                    <li><a href="/Home">博客首页</a></li>
                
                    <li><a href="/works">作品展示</a></li>
                
                    <li><a href="/about">留言打卡</a></li>
                
                    <li><a href="/FrontEndGuide">前端导航</a></li>
                
                <div class="clearfix"></div>
                </ul>
            </nav>
            <nav class="header-nav">
                <div class="social">
                    
                        <a class="mail" target="_blank" href="http://mail.qq.com/cgi-bin/qm_share?t=qm_mailme&email=PAkNDgsKBQ4MCnxNTRJfU1E" title="mail">mail</a>
                    
                        <a class="github" target="_blank" href="https://github.com/luuman" title="github">github</a>
                    
                        <a class="zhihu" target="_blank" href="https://www.zhihu.com/people/luuman" title="zhihu">zhihu</a>
                    
                        <a class="weibo" target="_blank" href="http://weibo.com/lishangmou" title="weibo">weibo</a>
                    
                        <a class="google" target="_blank" href="http://i.youku.com/shangmou" title="google">google</a>
                    
                        <a class="twitter" target="_blank" href="http: //twitter.com/luuman" title="twitter">twitter</a>
                    
                        <a class="facebook" target="_blank" href="#" title="facebook">facebook</a>
                    
                        <a class="rss" target="_blank" href="/atom.xml" title="rss">rss</a>
                    
                </div>
            </nav>
        </header>                
    </div>
</nav>
      <div class="body-wrap"><article id="post-Java中的异常处理" class="article article-type-post" itemscope itemprop="blogPost">
  
    <div class="article-meta">
      <a href="/2016/08/09/Java中的异常处理/" class="article-date">
      <time datetime="2016-08-09T07:32:40.000Z" itemprop="datePublished">2016-08-09</time>
</a>
    </div>
  
  <div class="article-inner">
    
      <input type="hidden" class="isFancy" />
    
    
      <header class="article-header">
        
  
    <h1 class="article-title" itemprop="name">
      Java中的异常处理
    </h1>
  

      </header>
      
      <div class="article-info article-info-post">
        

        
    <div class="article-tag tagcloud">
        <ul class="article-tag-list"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tags/java/">java</a></li></ul>
    </div>

        <div class="clearfix"></div>
      </div>
      
    
    <div class="article-entry" itemprop="articleBody">
      
          
        <p>异常在Java中是一个非常重要的概念，如果不用异常写程序，我们能写的代码寥寥无几，今天我们就看看java异常的一些注意事项。<br><a id="more"></a></p>
<h3 id="异常时才使用异常"><a href="#异常时才使用异常" class="headerlink" title="异常时才使用异常"></a>异常时才使用异常</h3><p>我们看如下代码：<br><figure class="highlight java"><table><tr><td class="gutter"><pre><div class="line">1</div><div class="line">2</div><div class="line">3</div><div class="line">4</div><div class="line">5</div><div class="line">6</div><div class="line">7</div><div class="line">8</div></pre></td><td class="code"><pre><div class="line"><span class="keyword">try</span>&#123;</div><div class="line">  <span class="keyword">int</span> i = <span class="number">0</span>;</div><div class="line">  <span class="keyword">while</span>(<span class="keyword">true</span>)&#123;</div><div class="line">    range[i++].climb();</div><div class="line">  &#125;</div><div class="line">&#125;<span class="keyword">catch</span>(ArrayIndexOutOfBoundsException e)&#123;</div><div class="line"></div><div class="line">&#125;</div></pre></td></tr></table></figure></p>
<p>上述代码就是一个典型的反模式，它使用异常来改变程序执行的顺序，这是一种不好的实践。我们要知道如果把代码放到try-catch中，会阻止JVM优化代码。这条建议不单单对代码有帮助，对设计api也有知道。我们考虑一下如果Iterator中没有hasNext测试方法会怎么样，代码会向下面一样：<br><figure class="highlight java"><table><tr><td class="gutter"><pre><div class="line">1</div><div class="line">2</div><div class="line">3</div><div class="line">4</div><div class="line">5</div><div class="line">6</div><div class="line">7</div></pre></td><td class="code"><pre><div class="line"><span class="keyword">try</span>&#123;</div><div class="line">  Iterator&lt;Foo&gt; i = collection.iterator();</div><div class="line">  <span class="keyword">while</span>(<span class="keyword">true</span>)&#123;</div><div class="line">    Foo foo = i.next();</div><div class="line">  &#125;</div><div class="line">&#125;<span class="keyword">catch</span>(NosuchElementException e)&#123;</div><div class="line">&#125;</div></pre></td></tr></table></figure></p>
<p>我们可以发现，如果没有hasNext方法，我们会迫使客户端用异常控制代码的执行过程，这也是我们在设计api中需要注意的。</p>
<h3 id="选择恰当的异常"><a href="#选择恰当的异常" class="headerlink" title="选择恰当的异常"></a>选择恰当的异常</h3><p>这条主要是针对设计api的，何时抛出受检异常，何时抛出运行时异常，何时抛出错误。<br>抛出受检异常的主要原则是：如果期望调用者能够适当地恢复，这种情况就应该使用受检异常。运行时异常和错误在行为上是等同的，它们都不需要也不应该被捕获。如果抛出错误或运行时异常，往往意味着代码不应该继续执行，这个错误是无法恢复的。按照惯例，我们只应该使用RuntimeException的子类，不应该使用Error，Error往往被JVM保留用于表示资源不足、约束失败等。</p>
<p>简单来说就是如果你认为客户能处理的问题就使用受检异常，如果用户不能处理或处理也只是退出程序而不能恢复错误，那么运行时异常是个不错的选择。</p>
<h3 id="优先使用标准异常"><a href="#优先使用标准异常" class="headerlink" title="优先使用标准异常"></a>优先使用标准异常</h3><p>这条实践不是告诉我们一定要使用jdk自带的异常，这句话的意思是代码应该抛出我们都能理解的异常，比如NullPointException，我们一眼就能明白这是什么错误。如果你抛出的异常更具有可读性，客户端一眼就能明白异常的原因，那么自定义异常也是一个不错的选择。最简单的实践就是异常转译，我们有时候会在代码的底层捕捉到异常，我们在异常链传递的过程中，在某个合适的位置将底层的异常转换为一个高层次能理解的异常。</p>
<h3 id="善用异常抛出的信息"><a href="#善用异常抛出的信息" class="headerlink" title="善用异常抛出的信息"></a>善用异常抛出的信息</h3><p>我们在抛出异常时可以保存一些关键信息，最直观的例子就是IndexOutOfBoundsException，它就包含了越界的下标，这样有助于我们快速定位错误地点。</p>
<h3 id="保持原子性"><a href="#保持原子性" class="headerlink" title="保持原子性"></a>保持原子性</h3><p>当对象抛出异常后，通常我们期望对象仍然在一种定义良好的可用状态，这对受检异常尤为重要，如果对象损坏修护起来就比较麻烦。一般而言，失败的方法调用应该使对象保持在调用之前的状态。具有这种特性的方法被称为具有失败原子性。我们看看Stack.pop方法<br><figure class="highlight java"><table><tr><td class="gutter"><pre><div class="line">1</div><div class="line">2</div><div class="line">3</div><div class="line">4</div><div class="line">5</div><div class="line">6</div><div class="line">7</div></pre></td><td class="code"><pre><div class="line"><span class="function"><span class="keyword">public</span> Object <span class="title">pop</span><span class="params">()</span></span>&#123;</div><div class="line">  <span class="keyword">if</span>(size == <span class="number">0</span>)</div><div class="line">    <span class="keyword">throw</span> <span class="keyword">new</span> EmptyStackException();</div><div class="line">  Object result = elements[--size];</div><div class="line">  elements[size] = <span class="keyword">null</span>;</div><div class="line">  <span class="keyword">return</span> result;</div><div class="line">&#125;</div></pre></td></tr></table></figure></p>
<p>我们考虑一下我们不加<code>if(size == 0)  throw new EmptyStackException();</code>这句话会怎样，我们不add，直接pop，后面代码一样会抛出异常，但是如果在后面的代码抛出了异常，size就为负数，对象就处在一个不正确的状态。下次在使用该对象会发生一些难以预料的错误。</p>
<p>我们如何可以保持失败的原子性呢？最简单的办法是将对象设计成不可变类，这样就不会存在什么不正确的状态；第二种办法是调整计算的顺序，使任何可能导致失败的计算放在修改对象前面；第三种是执行操作前，先对参数的有效性进行检查，可以在对象修改前抛出适当的异常，Stack.pop就是用这种方法；还有一种是先备份，执行成功后将原来的对象覆盖。</p>
<p>我们总希望能保持失败的原子性，但是有时候我们无能为例，尤其在多线程的时候，如果违反这条跪着，api文档应该说明会让对象处在什么状态。对于哪些不可恢复的问题，我们就不需要保持原子性，保持原子性就是为了继续运行程序。</p>

      
    </div>
    
  </div>
  
    
    <div class="copyright">
        <p><span>本文标题:</span><a href="/2016/08/09/Java中的异常处理/">Java中的异常处理</a></p>
        <p><span>文章作者:</span><a href="/" title="访问 Abely Liu 的个人博客">Abely Liu</a></p>
        <p><span>发布时间:</span>2016年08月09日 - 15时32分</p>
        <p><span>最后更新:</span>2016年08月10日 - 20时58分</p>
        <p>
            <span>原始链接:</span><a class="post-url" href="/2016/08/09/Java中的异常处理/" title="Java中的异常处理">http://yoursite.com/2016/08/09/Java中的异常处理/</a>
            <span class="copy-path" data-clipboard-text="原文: http://yoursite.com/2016/08/09/Java中的异常处理/　　作者: Abely Liu" title="点击复制文章链接"><i class="fa fa-clipboard"></i></span>
            <script src="/js/clipboard.min.js"></script>
            <script> var clipboard = new Clipboard('.copy-path'); </script>
        </p>
        <p>
            <span>许可协议:</span><i class="fa fa-creative-commons"></i> <a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/3.0/cn/" title="中国大陆 (CC BY-NC-SA 3.0 CN)" target = "_blank">"署名-非商用-相同方式共享 3.0"</a> 转载请保留原文链接及作者。
        </p>
    </div>



<nav id="article-nav">
  
    <a href="/2016/08/10/浅谈程序设计/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption"><</strong>
      <div class="article-nav-title">
        
          浅谈程序设计
        
      </div>
    </a>
  
  
    <a href="/2016/08/08/HashCode最佳实践/" id="article-nav-older" class="article-nav-link-wrap">
      <div class="article-nav-title">HashCode的最佳实践</div>
      <strong class="article-nav-caption">></strong>
    </a>
  
</nav>

  
</article>

    <div id="toc" class="toc-article">
    <strong class="toc-title">文章目录</strong>
    <ol class="toc"><li class="toc-item toc-level-3"><a class="toc-link" href="#异常时才使用异常"><span class="toc-number">1.</span> <span class="toc-text">异常时才使用异常</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#选择恰当的异常"><span class="toc-number">2.</span> <span class="toc-text">选择恰当的异常</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#优先使用标准异常"><span class="toc-number">3.</span> <span class="toc-text">优先使用标准异常</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#善用异常抛出的信息"><span class="toc-number">4.</span> <span class="toc-text">善用异常抛出的信息</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#保持原子性"><span class="toc-number">5.</span> <span class="toc-text">保持原子性</span></a></li></ol>
</div>
<input type="button" id="tocButton" value="隐藏目录"  title="点击按钮隐藏或者显示文章目录">

<script src="https://7.url.cn/edu/jslib/comb/require-2.1.6,jquery-1.9.1.min.js"></script>
<script>
    var valueHide = "隐藏目录";
    var valueShow = "显示目录";

    if ($(".left-col").is(":hidden")) {
        $("#tocButton").attr("value", valueShow);
    }
    $("#tocButton").click(function() {
        if ($("#toc").is(":hidden")) {
            $("#tocButton").attr("value", valueHide);
            $("#toc").slideDown(320);
        }
        else {
            $("#tocButton").attr("value", valueShow);
            $("#toc").slideUp(350);
        }
    })
    if ($(".toc").length < 1) {
        $("#toc, #tocButton").hide();
    }
</script>





<div class="bdsharebuttonbox">
	<a href="#" class="fx fa-weibo bds_tsina" data-cmd="tsina" title="分享到新浪微博"></a>
	<a href="#" class="fx fa-weixin bds_weixin" data-cmd="weixin" title="分享到微信"></a>
	<a href="#" class="fx fa-qq bds_sqq" data-cmd="sqq" title="分享到QQ好友"></a>
	<a href="#" class="fx fa-facebook-official bds_fbook" data-cmd="fbook" title="分享到Facebook"></a>
	<a href="#" class="fx fa-twitter bds_twi" data-cmd="twi" title="分享到Twitter"></a>
	<a href="#" class="fx fa-linkedin bds_linkedin" data-cmd="linkedin" title="分享到linkedin"></a>
	<a href="#" class="fx fa-files-o bds_copy" data-cmd="copy" title="分享到复制网址"></a>
</div>
<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"2","bdSize":"24"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>




    
      <div class="duoshuo" id="comments">
    <!-- 多说评论框 start -->
    <div class="ds-thread" data-thread-key="2016/08/09/Java中的异常处理/" data-title="Java中的异常处理" data-url="http://yoursite.com/2016/08/09/Java中的异常处理/"></div>
    <!-- 多说评论框 end -->
    <!-- 多说公共JS代码 start (一个网页只需插入一次) -->
    <script type="text/javascript">
    var duoshuoQuery = {short_name:"null"};
    (function() {
        var ds = document.createElement('script');
        ds.type = 'text/javascript';ds.async = true;
        ds.src = '/js/embed.js';
        ds.charset = 'UTF-8';
        (document.getElementsByTagName('head')[0] 
         || document.getElementsByTagName('body')[0]).appendChild(ds);
    })();
    </script>
    <!-- 多说公共JS代码 end -->
</div>

    



    <div class="scroll" id="post-nav-button">
        
            <a href="/2016/08/10/浅谈程序设计/" title="上一篇: 浅谈程序设计">
                <i class="fa fa-angle-left"></i>
            </a>
        
        <a title="文章列表"><i class="fa fa-bars"></i><i class="fa fa-times"></i></a>
        
            <a href="/2016/08/08/HashCode最佳实践/" title="下一篇: HashCode的最佳实践">
                <i class="fa fa-angle-right"></i>
            </a>
        
    </div>
    <ul class="post-list"><li class="post-list-item"><a class="post-list-link" href="/2016/08/12/Git常用命令/">Git常用命令</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/11/NodeJs换源/">NodeJs换源</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/11/如何配置sudo/">如何配置sudo</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/10/浅谈程序设计/">浅谈程序设计</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/09/Java中的异常处理/">Java中的异常处理</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/08/HashCode最佳实践/">HashCode的最佳实践</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/07/小心覆盖equals/">小心覆盖equals</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/06/Builder模式/">构建器模式</a></li><li class="post-list-item"><a class="post-list-link" href="/2016/08/05/Linux用户与权限管理/">Linux用户与权限</a></li></ul>
    <script src="https://7.url.cn/edu/jslib/comb/require-2.1.6,jquery-1.9.1.min.js"></script>
    <script>
        $(".post-list").addClass("toc-article");
        $(".post-list-item a").attr("target","_blank");
        $("#post-nav-button > a:nth-child(2)").click(function() {
            $(".fa-bars, .fa-times").toggle();
            $(".post-list").toggle(300);
            if ($(".toc").length > 0) {
                $("#toc, #tocButton").toggle(200, function() {
                    if ($(".switch-area").is(":visible")) {
                        $("#tocButton").attr("value", valueHide);
                        }
                    })
            }
            else {
            }
        })
    </script>



    <script>
        
    </script>
</div>
      <footer id="footer">
    <div class="outer">
        <div id="footer-info">
            <div class="footer-left">
                &copy; 2016 Abely Liu
            </div>
            <div class="footer-right">
                <a href="http://hexo.io/" target="_blank">Hexo</a>  Theme <a href="https://github.com/luuman/hexo-theme-spfk" target="_blank">spfk</a> by luuman
            </div>
        </div>
        
            <div class="visit">
                
                    <span id="busuanzi_container_site_pv" style='display:none'>
                        <span id="site-visit" >海贼到访数: 
                            <span id="busuanzi_value_site_uv"></span>
                        </span>
                    </span>
                
                
                    <span>, </span>
                
                
                    <span id="busuanzi_container_page_pv" style='display:none'>
                        <span id="page-visit">本页阅读量: 
                            <span id="busuanzi_value_page_pv"></span>
                        </span>
                    </span>
                
            </div>
        
    </div>
</footer>

    </div>
    <script src="https://7.url.cn/edu/jslib/comb/require-2.1.6,jquery-1.9.1.min.js"></script>
<script src="/js/main.js"></script>

    <script>
        $(document).ready(function() {
            var backgroundnum = 24;
            var backgroundimg = "url(/background/bg-x.jpg)".replace(/x/gi, Math.ceil(Math.random() * backgroundnum));
            $("#mobile-nav").css({"background-image": backgroundimg,"background-size": "cover","background-position": "center"});
            $(".left-col").css({"background-image": backgroundimg,"background-size": "cover","background-position": "center"});
        })
    </script>





<div class="scroll" id="scroll">
    <a href="#"><i class="fa fa-arrow-up"></i></a>
    <a href="#comments"><i class="fa fa-comments-o"></i></a>
    <a href="#footer"><i class="fa fa-arrow-down"></i></a>
</div>
<script>
    $(document).ready(function() {
        if ($("#comments").length < 1) {
            $("#scroll > a:nth-child(2)").hide();
        };
    })
</script>

<script async src="https://dn-lbstatics.qbox.me/busuanzi/2.3/busuanzi.pure.mini.js">
</script>

  <script language="javascript">
    $(function() {
        $("a[title]").each(function() {
            var a = $(this);
            var title = a.attr('title');
            if (title == undefined || title == "") return;
            a.data('title', title).removeAttr('title').hover(

            function() {
                var offset = a.offset();
                $("<div id=\"anchortitlecontainer\"></div>").appendTo($("body")).html(title).css({
                    top: offset.top - a.outerHeight() - 15,
                    left: offset.left + a.outerWidth()/2 + 1
                }).fadeIn(function() {
                    var pop = $(this);
                    setTimeout(function() {
                        pop.remove();
                    }, pop.text().length * 800);
                });
            }, function() {
                $("#anchortitlecontainer").remove();
            });
        });
    });
</script>


  </div>
</body>
</html>